## ● PRINTER RUSH ● (PTO ASSISTANCE)

| Application : <u>09/00</u> 242 | 2 Examiner : N           | hitmore GAU:                                               | 2812    |  |  |  |
|--------------------------------|--------------------------|------------------------------------------------------------|---------|--|--|--|
| From: TMCG1                    | Location:                | IDC) FMF FDC Date: /                                       | 1-3-05  |  |  |  |
|                                |                          | <u>M.D9/00242</u> 2 Week Date: /                           |         |  |  |  |
| DOC CODE                       | DOC DATE                 | MISCELLANEOUS                                              |         |  |  |  |
| ☐ 1449<br>☐ IDS<br>☐ CLM       |                          | ☐ Continuing Data ☐ Foreign Priority ☐ Document Legibility |         |  |  |  |
| ☐ IIFW<br>☐ SRFW<br>☑ DRW      | 8-12-05                  | Fees Other                                                 |         |  |  |  |
| ☐ OATH<br>☐ 312<br>☐ SPEC      |                          |                                                            |         |  |  |  |
| [RUSH] MESSAGE: 1              | An: Chief<br>Re are tu   | DRAFKSPERSON                                               | but     |  |  |  |
| no fi                          | gure 17.                 |                                                            |         |  |  |  |
|                                |                          |                                                            |         |  |  |  |
| Thank You                      |                          |                                                            |         |  |  |  |
| [XRUSH] RESPONSE:              |                          |                                                            |         |  |  |  |
|                                |                          |                                                            |         |  |  |  |
| Drawmes Corrected              |                          |                                                            |         |  |  |  |
| INITIALS:                      |                          |                                                            |         |  |  |  |
| NOTE: This form will be inc    | luded as part of the off | icial USPTO record, with the Resp                          | onse // |  |  |  |

**REV 10/04** 



FIG. 1

## 200

Compilers,
Runtime Libraries,
Utilities
220
Operating System 210

I/O Services
211

Memory
Management
212

| IC Netlist Builder Program 300           |
|------------------------------------------|
| User Interface Module 310                |
| Paramter Application Module 320          |
| Expert System Module 330                 |
| Chip Level Netlist Generation Module 340 |
| Verification Module 350                  |
|                                          |

```
proc do_timers{}

{
    if { $ { : : VPB0.TIMERS_numelements} > 0 } {
        set DSGN_PARAM "timer -tsize 32 -psize 32 -psize 32 -pcons '0' -pdmax 1 -nmr
NMR -extm Y_N_MASK -nc r NCR -t 2 -areset 2 -0 TIMERNAME"
    set i 0
    while {$ { : : VPB0.TIMERS_numelements > $i} } {
        set DSGN_PARAM_COPY $DSGN_PARAM
        #-- if we have only one timer we make sure
        #-- that we do not use index elements
        if {$ { : : VPB0.TIMERS_numelements} = 1 } {
            set devicename "timer"
            set tmpstr ""
        } else {
            set devicename "timer$i"
            set tmpstr "$i"
        }
}
```

## FIG 4A

regsub -all "NMR" \$DSGN\_PARAM\_COPY [set ::VPB0.TIMERS\$i.NUM\_MATCH] DSGN\_PARAM\_COPY regsub -all "Y\_N\_MASK" \$DSGN\_PARAM\_COPY [set ::VPB0.TIMERS\$i.MATCH\_INT] DSGN\_PARAM\_CO

PY

regsub -all "NMR" \$DSGN\_PARAM\_COPY [set ::VPB0.TIMERS\$i.NCR]
DSGN\_PARAM\_COPY
regsub -all "TIMERNAME" \$DSGN\_PARAM\_COPY \$ (devicename)
DSGN\_PARAM\_COPY

## FIG 4B

```
lappend::library_list "library $ {devicename}_lib; \nuse $ {devicename}_lib.$(devicename)_pkg.all; \n" lappend::vpb_dev_name $ {devicename} lappend:: gate_count [list - n "Timer $i" -g 6135 -sg"" -t Sy ]
```

```
lappened::sgnl_name "VPB Timer $devicename"
       lappened::sgnl_name "tmr$ {tmpstr}_pause | 111 "
       lappened : : clk_dst_name "ct_tmr${devicename}_pclk | ck_nbclk"
       set iinfo ""
       lappened iinfo "u_tmr$tmpstr | timer$tmpstr | VPB Timer $tmpstr"
       lappened iinfo "pclk | ct_tmr$ {tmpstr}_pclk | VPB Bus Clock"
       lappened iinfo "pstb | pstb | VPB Peripheral Strobe '
       lappened iinfo "psel | psel_tmr${tmpstr} | VPB Peripheral Select"
       lappened iinfo "pwrite | pwrite | VPB Peripheral Write"
       lappened iinfo "pd | pd | VPB Data Bus (31:0)"
       if ([set::VPB0.TIMERS$i.NCR] > 0) {
           lappend: : assign_list "Tie off capture Inputs ".
       lappend: : assign_list "tmr$ {tmr$(tmpstr}_capture | (expr (($:: LANGUAGE) = =
(LANG_VHDL)) ?{ (others =>logic_01) : {logic_0}} "
lappend iinfo "capture | tmr${(tmpstr)_capture | Timer Capture Signals"
       lappened::sgnl_name "tmr$ {tmpstr}_capture | set:: VPB0.TIMERS$i.NCR] |"
if { [set :: VPB0.TIMERS$i.NUM_MATCH] > 0} {
       lappened iinfo "nint | tmr${tmpstr}_int | Timer Interrupt, Active Low"
       lappened::intr_src "${devicename}_nint"
it { [set :: VPB0.TIMERS$i.NCR] > 0 / / [set :: VPB0.TIMERS$i.NUM_MATCH] > 0 } {
       lappened iinfo "pnres / ct_tmr$(tmpstr)_pures | VPB Asynchronous Timer Reset" lappened iinfo "pa | pa(5 downto 0) | VPB Address Bus (5:0)"
       lappened::rst_dst_name "rs_tmr$(tmpstr)_pnres | cg_nbclk"
} else {
       lappened iinfo "pa | pa(4 downto 0) | VPB Address Bus (5:0)"
lappend iinfo "pause | tmr$(tmpstr)_pause | Timer Pause"
lappend:: assign_list "Tie off pause Inputs"
lappend : : assign_list " tmr$(tmpstr)_pause | logic_0"
#-- Based on the number of match outputs, we create interrupt sources
if {[set::VPB0.TIMERS$i.MATCH_INT] = = 1} {
    set j 0
    while { [set :: VPB0.TIMERS$i.NUM_MATCH] > Sj} {
       lappend::intr_src "${devicename}_m$j"
       lappend iinfo "m$j | tmr${tmpstr}_m$j | Timer $tmpstr External Match $j Output
        incr j
    }
lappend iinfo "scantestmode I scantestmode I Scan Test Mode"
lappend :: inst_list $iinfo
```

```
proc create_chipcore {} {
     set ccfid [open "$:: WORK_DIR/S:: COMPONENTNAME/chip/top/chipcore.v"
# Module and port type declaration has already been written by padring.tcl
       foreach elem $ :: sgnl_name {
    regsub { [/t] +$} $elem {} elem
    set selem [split $elem "/"]
          switch [llength $selem] {
              1 { puts $ccfid "$ { : :comment} [string trim [lindex $selem 0]]" }
               2 { set swidth [lindex $selem 1]; puts $ccfid [format " wire %7s %s" [expr
($swi
dth==1)? {}: {\[[expr $swidth-1] \:0 \]}] "string trim [lindex $selem 0] ];" ]}
               3 { set swidth {lindex $selem 1}; puts $ccfid [format " wire %7s %-40s ${::
comme
nt) %s" [expr (swidth = 1) ? {}: {\[ [expr swidth - 1] \: 0\]}} "string trim [lindex selem
0]]; " [strin
g trim [lindex $selem 2]]]}
 }
                                            FIG 6A
    puts $ccfid "${:: comment} Reset and Clock signals"
foreach elem [ concat $ : : rst_dst_name $: : clk_dst_name] {
       set selem [split $elem "/"]
       puts $ccfid [ccfid [format "
                                     wire
                                                   %s; "[string trim [lindex $selem 0]]]
puts $ccfid "\n[string repeat $: : comment 30]"
puts Sccfid "$:: comment Assign statements"
puts $ccfid "\n[string repeat $: : comment 30] \n"
                                            FIG 6B
# Based on the assign_list, generate the HDL assign statements as required.
     foreach elem $ :: assign_list {
    regsub { [ /\t] + $elem { } elem
    set aelem [split $elem "/"]
         if { [llength $aelem]==1 } {
               puts $ccfid "${ :: comment} [lindex $aelem 0]"
             if \{S: LANGUAGE\} = "LANG_VHDL"\}
                  puts $ccfid [format " %15s <= %s; " [string trim [lindex $aelem 0]]
[string trim [lindex Saelem 1]]]
                       } else {
                           puts $ccfid [format "assign %15s = %s; "[string trim [lindex
$aelem 0 ] ] [string trim [lindex $aelem 1]]]
        }
```

```
proc create_chipcore {} {
      set ccfid [open "$:: WORK_DIR/ S:: COMPONENTNAME/chip/top/chipcore.v"
# Module and port type declaration has already been written by padring.tcl
# Based on the sgnl_name list, which contains all the internal signals
# that must be generated for proper connectively, create the actual
# VHDL or Verilog code that will perform that task.
        foreach elem $ :: sgnl_name {
     foreach iinfo $::inst_list { '
        set first 1
        set istr ""
        foreach pmap $iinfo {
           regsub -all { [\t] *\/ [\t]*} $pmap {/} pmap
           set pelem [split $pmap {/}]
           if { $first } {
               set first 0
                  append istr "\n${ :: comment) (string repeat $ {:: comment} 37] \n"
                 append istr "${ :: comment} [lindex $pelem 2]\n"
                 append istr "${ :: comment) (string repeat $ {:: comment} 37] \n"
             append istr " [lindex $pelem 1] [lindex $pelem 0] (\n"
             set formal [lindex $pelem 0]
             set actual [lindex $pelem 1]
             if {{$::LANGUÂGE} == "LANG_VERILOG"} {
                regsub -all {\() $actual {[] actual regsub -all {\() $actual {]} actual regsub {open} $actual {} actual
                regsub - all "downto " $actual ": " actual regsub {\(} $formal {[] formal regsub (\)} $formal {]} formal
                 regsub "downto "$formal ":" formal
            append istr "
                                .$formal ($actual), \n"
         regsub {, \n$} $istr "); "istr
         puts $ccfid $istr
```

puts \$ccfid "\n\nendmodule \n"

| Local Chip Builer                               |                                         |             |          |                     |            |
|-------------------------------------------------|-----------------------------------------|-------------|----------|---------------------|------------|
| File 811 Edit 81                                | 2                                       |             |          | 8                   | Help<br>13 |
| ASB Devices:<br>820                             |                                         | Edit<br>841 | Param    | neterize ASE<br>871 | 3 Devices  |
| VPB Devices:<br>821                             | Edit<br>842                             |             |          |                     |            |
| System Resource<br>823                          | Edit<br>843                             |             |          |                     |            |
| Deliverables Option:<br>822                     |                                         | Edit<br>844 |          |                     |            |
| User IOs:<br>824                                |                                         | Edit/Do     | elete/Ne | w                   |            |
| Component Name/Output File (no ext): cbbiic 831 |                                         |             |          |                     |            |
| Compile<br>851                                  | · • • • • • • • • • • • • • • • • • • • |             |          | Close<br>85         | 3          |

Fig 8

Fig 9

| Vpb0                                                          |      | 1005            |  |  |
|---------------------------------------------------------------|------|-----------------|--|--|
| VPB Based Watchdog Timer Parameters                           | 1010 | Edit            |  |  |
| VPB Based Timer Parameters                                    | 1011 | Edit/Delete/New |  |  |
| VPB Based UART/IrDA Parameters                                | 1012 | Edit/Delete/New |  |  |
| VPB Based I2C Parameters                                      | 1013 | Edit            |  |  |
| VPB Based USB Device Parameters                               | 1014 | Edit            |  |  |
| VPB Based GPIO Parameters                                     | 1015 | Edit            |  |  |
| VPB Based RTC Parameters                                      | 1016 | Edit            |  |  |
| VPB Based BBRAM Parameters                                    | 1017 | Edit            |  |  |
| VPB Based Interrupt Controller Parameters                     | 1018 | Edit            |  |  |
| Security Blocks: 1019                                         |      |                 |  |  |
| VPB Based Random Number Generator Parameters: Edit/Delete/New |      |                 |  |  |
| VPB Based Exponentiator Parameters                            |      | Edit/Delete/New |  |  |
| User Defined Config Register Groups                           | 1020 | Edit/Delete/New |  |  |
| VPB User Block Interface Paramenters                          | 1021 | Edit/Delete/New |  |  |
| Close 1022                                                    | lelp | 1023            |  |  |

Fig 10



**FIG 11** 



Fig 12



Fig 13

|           | Device Description 1410        |        |       |                           |              |                              |  |
|-----------|--------------------------------|--------|-------|---------------------------|--------------|------------------------------|--|
|           | Reporting: Chip IOs: 1421 1422 |        |       | Close<br>1423             |              |                              |  |
|           | Name                           | Туре   | Width | Pad Type                  | Multiplexing | Comment                      |  |
| $\square$ | 1431                           | 1432   | 1433  | 1434                      | 1435         | 1436                         |  |
|           | tck                            | input  | 1     | pc3d01                    |              | Test Interface Clock         |  |
|           | tms                            | input  | 1     | pc3d01                    |              | Test Mode Select             |  |
|           | tdi                            | input  | 1     | pc3d01                    |              | Test Data Input              |  |
|           | tdo                            | output | 1     | pc3d01                    |              | Test Data Output             |  |
|           | trst_n                         | input  | 1     | pc3d01                    |              | Test Reset Input             |  |
|           | extern                         | input  | 1     | pc3d01                    |              | rnal Input for conditonal bi |  |
|           | rangeout                       | output | 1     | pc3d01                    |              | ARM rangeout Output          |  |
|           | flash_we_n                     | output | 1     | pc3d01                    | :            | SDC flash Write Enable       |  |
|           | flash_we_n                     | output | 1     | pc3d01                    |              | SDC flash Output Enable      |  |
|           | flash_we_n                     | output | 2     | pc3d01                    |              | SDC flash Chip Select        |  |
|           | sram_we_n                      | output | 1     | pc3d01                    |              | SDC sram Write Enable        |  |
|           | sram_we_n                      | output | 1     | pc3d01                    |              | SDC sram Output Enable       |  |
| 1         | sram_we_n                      | output | 2     | pc3d01                    |              | SDC sram Chip Select         |  |
|           | ebiu_xa                        | output | 19    | pc3d01                    |              | EBIU ebiu External Address   |  |
| 121       | Total Ins                      |        | 5     |                           |              |                              |  |
|           | Total Out                      |        | 29    |                           |              |                              |  |
|           | Total Inou                     | uts    | 0     |                           |              |                              |  |
|           | Total IOs                      |        | 34    |                           |              |                              |  |
|           | Total Pwi                      | -      | 0     | (Required PLLS, Clocks)   |              |                              |  |
|           | Total Rin                      | _      | 10    | (Estimated 1pair per 8IO) |              |                              |  |
|           | Total Cor                      | e Pwrs | 10    | (Est. 1pair per 50k gate) |              |                              |  |
| 1         | Total Pin                      | s      | 54    | (Estimated)               |              |                              |  |
|           |                                |        | ,     |                           |              |                              |  |
|           |                                |        |       |                           |              |                              |  |
|           |                                |        |       |                           |              |                              |  |

Fig 14





FIG 16



FIG 17